package com.Dec_Six;

/**
 * 134. 加油站
 * 在一条环路上有 n 个加油站，其中第 i 个加油站有汽油 gas[i] 升。
 *
 * 你有一辆油箱容量无限的的汽车，从第 i 个加油站开往第 i+1 个加油站需要消耗汽油 cost[i] 升。你从其中的一个加油站出发，开始时油箱为空。
 *
 * 给定两个整数数组 gas 和 cost ，如果你可以绕环路行驶一周，则返回出发时加油站的编号，否则返回 -1 。如果存在解，则 保证 它是 唯一 的。
 *
 *  
 *
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode.cn/problems/gas-station
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 *
 * 2022/11/06 14:07
 */

public class Solution134 {

    public int canCompleteCircuit(int[] gas, int[] cost) {
        int start=0,curSum=0,totalSum=0;
        for (int i = 0; i < gas.length; i++) {
            curSum+=gas[i]-cost[i];
            totalSum+=gas[i]-cost[i];
            if (curSum<0)
            {
                start=i+1;
                curSum=0;
            }
        }
        if (totalSum<0) return -1;
        return start;
    }

    public static void main(String[] args) {
        Solution134 solution134=new Solution134();
        System.out.println(solution134.canCompleteCircuit(new int[]{2,3,4},new int[]{3,4,3}));
    }

}
